<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>

</head>
<body>
  <div id="app">
     <input type="text" v-model="a">
     <br>
     {{obj}}
     <br>
     <button @click="toChangeObj">点我改变obj数据</button>
  </div>
  <script>
    new Vue({
      el:'#app',
      data:{
        //   监听的是基本数据类型
        a:0,
        // 监听引用数据类型
        obj:{
            name:"zhangsan",
            age:15
        }
       
      },
      watch:{
        //  深度监听
        obj:{
            handler(newValue,oldValue){
                console.log(newValue,oldValue,111);
            },
            deep:true
        }
      },
    //   监听器 监听属性变化
    // watch:{
    //     a(newValue,oldValue){
    //        console.log('基本数据类型a的值发生了变化');
    //     },
    //     obj(){
    //         console.log('obj数据改变了');
    //     }
    // },
      methods:{
        toChangeObj(){
            this.obj.name='lisi'
        }
      }
    })
  </script>
</body>
</html>